﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.IO;
using System.Data;
using System.Configuration;
using Crosland.Automotriz.Logic.Linq;
using Crosland.Automotriz.Entidad;
using Microsoft.SqlServer.Dts.Runtime;

namespace Crosland.Automotriz.Web.Minorista
{
    public partial class wFrmSeguroVehicularCarga : System.Web.UI.Page
    {
        private static String RutaExcel = "";
        
        string idNegocio = ConfigurationManager.AppSettings["Negocio"];

        protected void Page_Load(object sender, EventArgs e)
        {
            if (Page.IsPostBack == false) 
            {
                cboAnioFactura.Value = DateTime.Now.Year;
                cboMesFactura.Value = DateTime.Now.Month.ToString();
            }
            if (cboTipoFiltro.SelectedIndex == 0)
            {
                Listar();
            }
            else
            {
                Listar_x_Poliza();
            }
        }

        protected void btnCargarExcel_Click(object sender, EventArgs e)
        {
            try
            {
                bool resultado = false;
                if (RutaExcel.Length == 0)
                {
                    string scriptOK = "ShowPopupPopupSeleccione();";
                    ScriptManager.RegisterStartupScript(this, typeof(Page), "carga", scriptOK, true);
                }
                else
                {
                    resultado = Execute_Package();
                    if (resultado == true)
                    {
                        Listar();
                        RutaExcel = "";
                        btnCargarExcel.Enabled = false;
                        ucCargador.Enabled = false;
                        pcCargarExcel.ShowOnPageLoad = false;
                        string scriptOK = "MostrarMensaje();";
                        lblMensaje.Text = "Datos registrados satisfactoriamente.";
                        ScriptManager.RegisterStartupScript(this, typeof(Page), "carga", scriptOK, true);
                    }
                }
            }
            catch (Exception ex)
            {
                pcCargarExcel.ShowOnPageLoad = false;
                string scriptOK = "MostrarMensaje();";
                lblMensaje.Text = ex.Message;
                ScriptManager.RegisterStartupScript(this, typeof(Page), "carga", scriptOK, true);
            }
        }

        protected void ucCargador_FileUploadComplete(object sender, DevExpress.Web.ASPxUploadControl.FileUploadCompleteEventArgs e)
        {
            try
            {
                if (e.IsValid)
                {


                    string filePath = Server.MapPath("~/Archivos Excel/GestionRegistro.xlsx");
                    
                    e.UploadedFile.SaveAs(filePath);
                    RutaExcel = filePath;
                }
            }
            catch
            {

            }
        }

        protected void btnSalir_Click(object sender, EventArgs e)
        {
            Response.Redirect("~/Repuestos/wFrmDefault.aspx?id=" + idNegocio);
        }

        private bool Execute_Package()
        {
            try
            {
                clsT_Ven_Cartas_Veh_ImpresionLogic bl = new clsT_Ven_Cartas_Veh_ImpresionLogic();
                bl.GestionRegistroEnviarData();
                return true;
            }
            catch (Exception ex)
            {
                pcCargarExcel.ShowOnPageLoad = false;
                string script = "MostrarMensaje();";
                lblMensaje.Text = ex.Message; ;
                ScriptManager.RegisterStartupScript(this, typeof(Page), "carga", script, true);
                return false;
            }
        }

        protected void btnImportarExcel_Click(object sender, EventArgs e)
        {
            pcCargarExcel.ShowOnPageLoad = true;
            btnCargarExcel.Enabled = true;
            ucCargador.Enabled = true;
        }

        void Listar() 
        {
            int anio = int.Parse(cboAnioFactura.Value.ToString());
            int mes = int.Parse(cboMesFactura.Value.ToString());

            clsT_Ven_Cartas_Veh_ImpresionLogic bl = new clsT_Ven_Cartas_Veh_ImpresionLogic();
            gv.DataSource = bl.Listar(anio, mes);
            gv.DataBind();
        }

        void Listar_x_Poliza() 
        {
            int anio = int.Parse(cboAnioFactura.Value.ToString());
            int mes = int.Parse(cboMesFactura.Value.ToString());

            clsT_Ven_Cartas_Veh_ImpresionLogic bl = new clsT_Ven_Cartas_Veh_ImpresionLogic();
            gv.DataSource = bl.Listar_x_Poliza(anio, mes);
            gv.DataBind();
        }

        protected void cboAnioFactura_SelectedIndexChanged(object sender, EventArgs e)
        {
            if (cboTipoFiltro.SelectedIndex == 0)
            {
                Listar();
            }
            else 
            {
                Listar_x_Poliza();
            }
        }

        protected void cboMesFactura_SelectedIndexChanged(object sender, EventArgs e)
        {
            if (cboTipoFiltro.SelectedIndex == 0)
            {
                Listar();
            }
            else 
            {
                Listar_x_Poliza();
            }
        }

        protected void cboTipoFiltro_SelectedIndexChanged(object sender, EventArgs e)
        {
            if (cboTipoFiltro.SelectedIndex == 0)
            {
                Listar();
            }
            else
            {
                Listar_x_Poliza();
            }
        }

    }
}